<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>2.监视属性实现_姓名案例</title>
		<!-- 引入开发版本的Vue -->
		<script type="text/javascript" src="../js/vue.js"></script>
	</head>
	<body>
		<!-- 准备好一个容器-->
		<div id="root">
			姓：<input type="text" v-model="person.firstName"> <br>
			名：<input type="text" v-model="person.lastName"> <br>
			全名：<span>{{person.fullName}}</span> <br>
		</div>
	</body>

	<script type="text/javascript">
		Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。

		new Vue({
			el:'#root',
			data:{
				person:{
					firstName:'张',
					lastName:'三',
					fullName:''
				}
			},
			watch:{
				person:{
					deep:true,
					immediate:true,
					handler(value){
						// console.log('@',)
						const str = value.firstName + '-' +value.lastName
						// //开启了一个异步任务
						setTimeout(()=>{
							console.log(this)
						this.person.fullName = str
						},500)
					}
				}
			}
		})
	</script>
</html>